using System. Threading. Tasks; 

using Microsoft.AspNetCore.Authorization; 
using Microsoft.AspNetCore. Identity; 
using Microsoft.AspNetCore.Mvc; 

using MyCompany.Models; 


namespace MyCompany.Controllers 
{ 
[Authorize] 
public class AccountController : Controller 
{ 
private readonly UserManager<ldentityUser> userManager; 
private readonly SignInManager<ldentityUser> signinManager; 
public AccountController(UserManager<lIdentityUser> userMgr, 
SigninManager<identityUser> signinMgr) 
{ 
userManager = userMgr; 
signinManager = signinMgr; 


} 


[AllowAnonymous] 
public |ActionResult Login(string returnUrl) 


{ 
ViewBag.returnUrl = returnUrl; 
return View(new LoginViewModel()); 
} 
[HttpPost] 


[AllowAnonymous] 
public async Task<lActionResult> Login(LoginViewModel model, string returnUrl) 
{ 
if (ModelState. IsValid) 
{ 
IdentityUser user = await userManager.FindByNameAsync(model.UserName); 
if (user != null) 
{ 
await signinManager.SignOutAsync(); 
Microsoft.AspNetCore.Identity.SignInResult result = await 
signinManager.PasswordSigninAsync(user, model.Password, model.RememberMe, false); 
if (result. Succeeded) 
{ 
return Redirect(returnUrl ?? "/"); 
} 
} 
ModelState.AddModelError(nameof(LoginViewModel.UserName), "HeBepHbin 
HOrUH nnn napons"); 
} 


return View(model); 


} 


[Authorize] 

public async Task<lActionResult> Logout() 

{ 
await signinManager.SignOutAsync(); 
return RedirectToAction("Index", "Home"); 

} 

} 
} 


